# Adder and Subtractor Unit

COE 328-022 Pei Yang

Oct 11 2022

### Introduction

The objective of this lab was to design an adder/subtracter unit using VHDL code and block diagrams that would add or subtract values depending on a Cin input. The experiment was split into two parts.

## Experiment

#### Part A:



### Part B:



| Name        | Value at    | 0 ps<br>0 ps | 10.0 ns | 20.0 ns | 30.0 ns | 40.0 ns | 50.0 ns | 60.0 ns | 70.0 ns | 80.0 ns | 90.0 ns | 100.0 ns |
|-------------|-------------|--------------|---------|---------|---------|---------|---------|---------|---------|---------|---------|----------|
| Name        | 0 ps        | 0 ps         |         |         |         |         |         |         |         |         |         |          |
| _ Cin       | B 0         |              |         |         |         |         |         |         |         |         |         |          |
| display     | B X111000   |              |         |         |         |         | X111000 |         |         |         |         |          |
| displa      | . B 0       |              |         |         |         |         |         |         |         |         |         |          |
| neg_d       | . B X000000 |              |         |         |         |         | X000000 |         |         |         |         |          |
| neg_d       | . B 0       |              |         |         |         |         |         |         |         |         |         |          |
| <b>≥</b>    | B 0010      |              |         |         |         |         | 0010    |         |         |         |         |          |
| _ X[3]      | B 0         |              |         |         |         |         |         |         |         |         |         |          |
| - X[2]      | B 0         |              |         |         |         |         |         |         |         |         |         |          |
| _ X[1]      | B 1         |              |         |         |         |         |         |         |         |         |         | _        |
| _ X[0]      | B 0         |              |         |         |         |         |         |         |         |         |         |          |
| <u>-</u> -Y | B 0100      |              |         |         |         |         | 0100    |         |         |         |         |          |
| - Y[3]      | B 0         |              |         |         |         |         |         |         |         |         |         |          |
| - Y[2]      | B 1         |              |         |         |         |         |         |         |         |         |         |          |
| - Y[1]      | B 0         |              |         |         |         |         |         |         |         |         |         |          |
| Y[0]        | B 0         |              |         |         |         |         |         |         |         |         |         |          |

library ieee;

USE ieee.std\_logic\_1164.all;

```
ENTITY C IS
```

PORT(

S: IN STD\_logic\_vector(3 DOWNTO 0);

L : OUT STD\_logic\_vector(3 DOWNTO 0)

); END C;

# ARCHITECTURE Behavior OF C IS BEGIN

 $L(3) \leftarrow (S(3) \text{ AND NOT } S(2) \text{ AND NOT } S(1) \text{ AND } S(0));$ 

 $L(2) \leftarrow (S(3) \text{ AND NOT } S(2) \text{ AND NOT } S(1) \text{ AND NOT } S(0)) \text{ OR } (S(3) \text{ AND NOT } S(2) \text{ AND NOT } S(1) \text{ AND NOT } S(0)) \text{ OR } (NOT S(3) \text{ AND } S(2) \text{ AND } S(1));$ 

 $L(1) \le (NOT S(3) AND S(2) AND S(0)) OR (NOT S(3) AND S(2) AND S(1));$ 

 $L(0) \leftarrow (NOT S(3) AND NOT S(1)) OR (NOT S(3) AND NOT S(2) AND S(0)) OR (NOT S(3) AND S(2) AND S(1) AND NOT S(0)) OR (S(3) AND NOT S(2) AND NOT S(1)); END Behavior;$ 

#### Conclusion

In part B, the circuit output the sum of two numbers, to a maximum of 9. This number corresponds a digit in our student numbers. Initially, we expected the waveform output to resemble the actual sum of the numbers and thought there was an error in our file. Eventually, we realized the waveform output matched a digit to our student numbers, not the actual sum of the input numbers.